<template>
  <div class="register-container">
    <article class="header">
      <header>
        <el-avatar icon="el-icon-user-solid" shape="circle" />
        <span class="login">
          <em class="bold">已有账号？</em>
          <router-link to="/login">
             <el-button type="primary" size="mini">登录</el-button>
          </router-link>
<!--          <a href="/login" >-->
<!--            <el-button type="primary" size="mini">登录</el-button>-->
<!--          </a>-->
        </span>
      </header>
    </article>
    <section>
      <el-form
        ref="ruleForm"
        :model="ruleForm"
        :rules="rules"
        label-width="100px"
        autocomplete="off"
        :hide-required-asterisk="true"
        size="medium"
      >
        <div style="padding-top: 10px">
          <el-form-item label="账号" prop="account">
            <el-col :span="10">
              <el-input v-model="ruleForm.account" />
            </el-col>
          </el-form-item>
          <el-form-item label="真实姓名" prop="name">
            <el-col :span="10">
              <el-input v-model="ruleForm.name" />
            </el-col>
          </el-form-item>
          <el-form-item label="电话" prop="tele">
          <el-col :span="10">
            <el-input v-model="ruleForm.tele" />
          </el-col>
        </el-form-item>
          <el-form-item label="单位" prop="unit">
          <el-col :span="10">
            <el-input v-model="ruleForm.unit" />
          </el-col>
        </el-form-item> <el-form-item label="职位" prop="position">
          <el-col :span="10">
            <el-input v-model="ruleForm.position" />
          </el-col>
        </el-form-item>
          <el-form-item label="邮箱" prop="email">
            <el-col :span="10">
              <el-input
                v-model="ruleForm.email"
                placeholder="输入邮箱并点击发送验证码"
              />
            </el-col>
            <el-button
              :loading="codeLoading"
              :disabled="isDisable"
              size="small"
              round
              @click="sendMsg"
            >发送验证码</el-button>

            <span class="status">{{ statusMsg }}</span>
          </el-form-item>
          <el-form-item label="验证码" prop="code">
            <el-col :span="10">
              <el-input
                v-model="ruleForm.code"
                maxlength="8"
                placeholder="请登录邮箱接收验证码"
              />
            </el-col>
          </el-form-item>
          <el-form-item label="邀请码" prop="invite">
            <el-col :span="10">
              <el-input
                  v-model="ruleForm.invite"
                  maxlength="8"
                  placeholder="请联系管理员获取邀请码"
              />
            </el-col>
          </el-form-item>
          <el-form-item label="密码" prop="pwd">
            <el-col :span="10">
              <el-input v-model="ruleForm.pwd" type="password" />
            </el-col>
          </el-form-item>
          <el-form-item label="确认密码" prop="cpwd">
            <el-col :span="10">
              <el-input v-model="ruleForm.cpwd" type="password" />
            </el-col>
          </el-form-item>
          <el-form-item>
            <el-button
              type="primary"
              style="width: 40%"
              @click="register"
            >注册</el-button>
          </el-form-item>
        </div>
      </el-form>
    </section>

    <div class="error">{{ error }}</div>
  </div>
</template>

<script>
// import { getEmailCode, user } from '@/api/user'
// import { encrypt } from '@/utils/rsaEncrypt'
import http from "@/utils/request";

export default {
  name: "register",
  data() {
    return {

      statusMsg: '',
      error: '',
      isDisable: false,
      codeLoading: false,
      ruleForm: {
        name:'',
        unit:'',
        position:'',
        tele:'',
        account:'',
        email: '',
        code: '',
        invite:'',
        pwd: '',
        cpwd: ''
      },
      rules: {
        name: [{
          required: true,
          type: 'string',
          message: '真实姓名',
          trigger: 'blur',
        },{pattern:/^[\u4e00-\u9fa5]{2,4}$/,message:'请输入正确姓名'}
        ],
        account: [{
          required: true,
          type: 'string',
          message: '账户名',
          trigger: 'blur'
        }],
        email: [{
          required: true,
          type: 'email',
          message: '请输入邮箱',
          trigger: 'blur'
        },
          {pattern:/^\w+([-+.]\w+)*@\w+([-.]\w+)*\.(com|cn|net)$/,message:'请输入正确邮箱'}
        ],
        code: [{
          required: true,
          type: 'string',
          message: '请输入验证码',
          trigger: 'blur'
        }],
        invite: [{
          required: true,
          type: 'string',
          message: '请输入邀请码',
          trigger: 'blur'
        }],
        pwd: [{
          required: true,
          message: '创建密码',
          trigger: 'blur'
        }, { pattern: /^(?=.*[A-Za-z])(?=.*\d)[A-Za-z\d]{6,20}$/, message: '密码必须同时包含数字与字母,且长度为 6-20位' }],
        cpwd: [{
          required: true,
          message: '确认密码',
          trigger: 'blur'
        }, {
          validator: (rule, value, callback) => {
            if (value === '') {
              callback(new Error('请再次输入密码'))
            } else if (value !== this.ruleForm.pwd) {
              callback(new Error('两次输入密码不一致'))
            } else {
              callback()
            }
          },
          trigger: 'blur'
        }]

      }
    }
  },
  methods: {
    sendMsg: function() {
      const self = this
      let emailPass
      let timerid
      if (timerid) {
        return false
      }
      self.statusMsg = ''
      this.$refs['ruleForm'].validateField('email', (valid) => {
        emailPass = valid
      })
      // 向后台API验证码发送
      if (!emailPass) {
        self.codeLoading = true
        self.statusMsg = '验证码已发送...'
        http.get('/users/send/',{params:{
            email:self.ruleForm.email
        }}).then((res)=>{
          let count = 60
          self.ruleForm.code = ''
          self.codeLoading = false
          self.isDisable = true
          self.statusMsg = `验证码已发送,${count--}秒后重新发送`
          timerid = window.setInterval(function() {
            self.statusMsg = `验证码已发送,${count--}秒后重新发送`
            if (count <= 0) {
              window.clearInterval(timerid)
              self.isDisable = false
              self.statusMsg = ''
            }
          }, 1000)
        }).catch(err => {
          console.log(err.response)
          this.isDisable = false
          this.statusMsg = ''
          this.codeLoading = false
          console.log(err)
        })

        // getEmailCode(self.ruleForm.email).then(res => {
        //   this.$message({
        //     showClose: true,
        //     message: '发送成功，验证码有效期5分钟',
        //     type: 'success'
        //   })

      }
      else alert('wrong'+emailPass  )
    },

    // 用户注册
    register: function() {
      // console.log(sessionStorage.getItem('verify_code'))
      this.$refs['ruleForm'].validate((valid) => {
        if (valid) {
          // const user = {
          //   code: this.ruleForm.code,
          //   email: this.ruleForm.email,
          //   //这里删除源码的加密
          //   password: this.ruleForm.pwd
          // }
          const params = new URLSearchParams();
          params.append('username', this.ruleForm.account);
          params.append('password', this.ruleForm.pwd);
          params.append('email', this.ruleForm.email);
          params.append('security_code', this.ruleForm.code);
          params.append('invite_code', this.ruleForm.invite);
          params.append('realname', this.ruleForm.name);
          params.append('telephone', this.ruleForm.tele);
          params.append('unit', this.ruleForm.unit);
          params.append('position', this.ruleForm.position);

          // http.post('/users/register/',{
          //   params:{
          //     username:this.ruleForm.account,
          //     email:this.ruleForm.email,
          //     password:this.ruleForm.pwd,
          //     security_code:this.ruleForm.code,
          //     invite_code:this.ruleForm.invite,
          //     realname:this.ruleForm.name,
          //     telephone:this.ruleForm.tele,
          //     unit:this.ruleForm.unit,
          //     position:this.ruleForm.position
          //   }
          http.post('/users/register/',params).then((res)=>{
            if (res.data.message===1){
              this.$message({
                showClose: true,
                message: res.data.data,
                type: 'warning'
              });
              // 跳转回登录
              this.$router.push('/login')
            }
           else {
              alert(res.data.data)
            }
          }).catch((error)=>{
            alert(error)
          })
          // user(user).then(res => {
          //   console.log(res)
          //   this.$message({
          //     showClose: true,
          //     message: '注册成功，正在跳转到登录界面...',
          //     type: 'success'
          //   })
          //   setTimeout(() => {
          //     this.$router.push('/')
          //   }, 2000)
          // }).catch(err => {
          //   console.log(err.response.data.message)
          // })
        }
        else {
          this.$message({
            showClose: true,
            message:'请检查信息是否正确',
            type: 'warning'
          });
        }
      })
    }
  }
}
</script>

<style lang="scss">
/* 修复input 背景不协调 和光标变色 */
/* Detail see https://github.com/PanJiaChen/vue-element-admin/pull/927 */

$bg: #283443;
$light_gray: #fff;
$cursor: #fff;

@supports (-webkit-mask: none) and (not (cater-color: $cursor)) {
  .register-container .el-input input {
    color: $cursor;
  }
}

/* reset element-ui css */
.register-container {
  .el-input {
    display: inline-block;
    height: 47px;
    width: 95%;

    input {
      background: rgba(0, 0, 0, 0.1);
      border-radius: 5px;
      border: 1px solid rgba(255, 255, 255, 0.1);
      -webkit-appearance: none;
      padding: 12px 5px 12px 15px;
      color: $light_gray;
      height: 47px;
      caret-color: $cursor;

      &:-webkit-autofill {
        box-shadow: 0 0 0px 1000px $bg inset !important;
        -webkit-text-fill-color: $cursor !important;
      }
    }
  }

  .el-form-item {
    label {
      font-style: normal;
      font-size: 12px;
      color: $light_gray;
    }
  }
}
</style>

<style lang="scss" scoped>
$bg: #2d3a4b;
$dark_gray: #889aa4;
$light_gray: #eee;

.register-container {
  min-height: 100vh;
  width: 100%;
  background-color: $bg;
  overflow: hidden;

  .header {
    border-bottom: 2px solid rgb(235, 232, 232);
    min-width: 980px;
    color: #666;

    header {
      margin: 0 auto;
      padding: 10px 0;
      width: 980px;

      .login {
        float: right;
      }

      .bold {
        font-style: normal;
        color: $light_gray;
      }
    }
  }

  > section {
    margin: 0 auto 30px;
    padding-top: 30px;
    width: 980px;
    min-height: 300px;
    padding-right: 100px;
    box-sizing: border-box;

    .status {
      font-size: 12px;
      margin-left: 20px;
      color: #e6a23c;
    }

    .error {
      color: red;
    }
  }

  .tips {
    float: right;
    font-size: 14px;
    color: #fff;
    margin-bottom: 10px;

    span {
      &:first-of-type {
        margin-right: 16px;
      }
    }
  }
}
</style>

<style scoped>
/* 修改验证器样式 */
::v-deep .el-form-item.is-error .el-input__inner {
  border-color: #889aa4;
}
::v-deep .el-form-item.is-error .el-input__validateIcon {
  color: #889aa4;
}
::v-deep .el-form-item__error {
  color: #e6a23c;
}
</style>
